草庐IT

SQL 表设置建议

全部标签

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir

ruby - 从 ActiveRecord 原始 SQL 获取类型化结果

在Sequel中,我可以做到:irb(main):003:0>DB["selectfalse"].get=>false返回一个错误的bool值。我希望能够在ActiveRecord中做类似的事情:irb(main):007:0>ActiveRecord::Base.connection.select_value"selectfalse"=>"f"如您所见,它返回字符串"f"。有没有办法用ActiveRecord得到一个错误的bool值?(类似地,我可能正在调用一个返回timestamptz、数组等的函数——我希望返回的值具有正确的类型)我的用例:我正在调用一个数据库函数,想要返回一个键

sql - GROUP BY 和 COUNT 使用 ActiveRecord

引用这个:IsthereanydifferencebetweenGROUPBYandDISTINCTGivenatablethatlookslikethis:name------barrydavebilldavedavebarryjohnThisquery:SELECTname,count(*)AScountFROMtableGROUPBYname;Willproduceoutputlikethis:namecount-------------barry2dave3bill1john1对于ActiveModel使用COUNT执行GROUPBY的正确Rails约定是什么?

ruby-on-rails - 如何为电子邮件设置 Devise 发件人姓名

尽管thisthread话不多说,我想你是这样在Devise初始化程序中设置发件人姓名的:app/config/initializers/devise.rbDevise.setupdo|config|config.mailer_sender="'MySite'"end但这对我不起作用。有谁知道正确的做法吗? 最佳答案 就是这样:config.mailer_sender='"Example.com"' 关于ruby-on-rails-如何为电子邮件设置Devise发件人姓名,我们在Stac

ruby-on-rails - 尝试为 ror 应用程序设置 postgres,出现错误 - fe_sendauth : no password supplied

获得:Anerrorhasoccurred:Errorconnectingtotheserver:fe_sendauth:nopasswordsupplieddatabase.yml中的设置与其他机器上的应用设置相同。我如何设置才能不需要硬编码密码?我可以使用PgAdmin-III查看数据库。我宁愿不要在database.yml中设置密码,因为使用此应用程序的其他机器没有/不需要密码,所以这似乎与我的Pg安装有关。 最佳答案 您需要更改您的pg_hba.conf。这是我的一个例子:pg_hba.conf:TYPEDATABASEUS

ruby-on-rails - 使用 Capistrano 3 设置默认阶段

有没有办法在Capistrano3中设置默认阶段?我试过将set:stage,:production放在deploy.rb中,但这没有用,它给出了错误:Stagenotset,pleasecallsomethingsuchas`capproductiondeploy`,whereproductionisastageyouhavedefined我现在只有一个阶段,所以我希望能够只运行capdeploy并让它在默认情况下执行。 最佳答案 Capistranov3在某种程度上是Rake的包装器,因此您需要意识到真正发生的是producti

ruby-on-rails - 如何在 Rails 中为 Mechanize 设置自定义用户代理

我知道你有一组预定义的别名,你可以通过设置agent.user_agent_alias='LinuxMozilla'来使用,但是如果我想设置我自己的用户代理,因为我正在写一个网络爬虫并想要识别它,为了我索引的网站。就像Googlebot。似乎有一个user_agent方法,但我似乎找不到任何关于它的功能的文档。 最佳答案 您可以从别名设置用户代理a=Mechanize.newa.user_agent_alias='MacSafari'可用别名存储在AGENT_ALIASES常量中。pMechanize::AGENT_ALIASES否

ruby - 有没有办法为 heroku 上的 Ruby on Rails 应用程序设置简单的 http 身份验证?

我想使用简单的http身份验证在heroku上设置一个私有(private)登台服务器。这可能吗? 最佳答案 一种更简洁的方法是将几行Rack中间件放入您的暂存环境配置中,单独留下Controller逻辑:#config/environments/staging.rbMyApp::Application.configuredoconfig.middleware.insert_after(::Rack::Lock,"::Rack::Auth::Basic","Staging")do|u,p|[u,p]==['username','pa

ruby - 如何在外部设置Ruby的加载路径

我有一个自定义的Ruby库目录,我希望在执行Ruby时将其自动添加到Ruby的加载路径中。我知道我可以对Ruby使用-I选项,但是有没有我可以设置的环境变量之类的东西,它将全局确定Ruby的加载路径。我想在没有root权限的Linux机器上安装RubyGems,因此我需要在非标准位置有一个Ruby加载路径。我根据“InstallingRubyGemsinaUserDirectory”安装了RubyGems,但gem命令没有选择非标准加载路径。也许我在这里遗漏了一些明显的东西并且让事情变得更难了? 最佳答案 请参阅ThePickaxe

Ruby:使用字符串/符号获取/设置对象的属性

在Ruby中,如何使用字符串/符号获取和设置对象的属性?例如,如果我有一个对象car,其属性为car.color和car.name。我知道您可以执行car.send(:color)来获取它的属性,但我该如何设置它呢? 最佳答案 car.send("name=",value)或者car.send("color=",value) 关于Ruby:使用字符串/符号获取/设置对象的属性,我们在StackOverflow上找到一个类似的问题: https://stacko